查看原文
其他

写一个在线位图字体制作工具!BitmapFont!

lamyoung 白玉无冰 2022-06-10

简单易用,跨平台,20KB!

效果

效果预览:

https://www.bilibili.com/video/BV1cf4y1H7Pa

无论写代码还是写工具,都要明确输入与输出。

  • 输入:零碎的字体图片(通常是数字)
  • 处理:可动态调整参数,预览实时效果
  • 输出:一张合图以及字体信息文件xxx.fnt

为何要重新写一个轮子呢?

  • Glyph Designer(Mac) 与 BMFont (Windows) 功能完善,但是有平台限制。个人不习惯其操作
  • Cocos Store 中也有许多优秀的 BMFont 插件,但是依赖 Cocos Creator,可能会有对应版本限制。

实现

于是动手写一个 HTML,依赖浏览器的小工具,目录设计如下:

  • index.html
  • renderer.js
  • index.css

拖入文件

参考mozilla中的文档,监听ondrop事件。

https://developer.mozilla.org/zh-CN/docs/Web/API/File/Using_files_from_web_applications

拖入文件后,用一个列表维护文件数据,文件格式可以参文档。

http://www.angelcode.com/products/bmfont/doc/file_format.html

  拖入文件代码

合成大图

参考 Cocos Store 中的一个插件代码,将所有图绘制在一个Canvas上。
http://store.cocos.com/app/detail/2604

合成大图代码

预览效果

根据图片xoffset yoffset xadvance的信息,采用 Canvas 画布渲染。

预览效果代码

导出文件

直接使用FileSaver.js

https://github.com/eligrey/FileSaver.js

导出文件代码

体验

在线体验地址:https://lamyoung.gitee.io/web/bitmapFont/

代码打包下载:https://gitee.com/lamyoung/web/raw/master/bitmapFont/source.zip

以上为白玉无冰使用 HTML + JS 实现 "位图字体制作工具" 的过程分享。


替代 toDataURL 的方案
Fake3D && Shader
MatCap && Shader
如何抄shader
3D折纸
渐变色文字3.0

点击“阅读原文”查看精选导航

“点赞“ ”在看” 鼓励一下

您可能也对以下帖子感兴趣

文章有问题?点此查看未经处理的缓存